<script setup>
import PageContainer from '@/components/PageContainer.vue'
import ChannelEdit from './components/ChannelEdit.vue'
import { Edit, Delete } from '@element-plus/icons-vue'
import { artGetChannelsService, artDelChannelService } from '@/api/article'
import { ref } from 'vue'
import { ElMessage, ElMessageBox } from 'element-plus'
const channelList = ref([])
const loading = ref(false)
const dialog = ref()
const getChannelList = async () => {
  loading.value = true
  const res = await artGetChannelsService()
  console.log(res)
  channelList.value = res.data.data
  loading.value = false
}
getChannelList()
const onDeleteChannel = async (row, $index) => {
  await ElMessageBox.confirm('你确认要删除该分类吗', '温馨提示', {
    type: 'warning',
    confirmButtonText: '确认',
    cancelButtonText: '取消'
  })
  console.log(row, $index)
  await artDelChannelService(row.id)
  ElMessage('删除成功')
  getChannelList()
}
const onEditChannel = (row) => {
  console.log(row)
  dialog.value.open(row)
}

const onAddChannel = () => {
  dialog.value.open({})
}
const onSuccess = () => {
  getChannelList()
}
</script>
<template>
  <PageContainer title="文章分类">
    <template #extra>
      <el-button type="primary" @click="onAddChannel">添加分类</el-button>
    </template>
    <template #body1>
      <ChannelEdit ref="dialog" @success="onSuccess"></ChannelEdit>
      <el-table v-loading="loading" :data="channelList" style="width: 100%">
        <el-table-column label="序号" width="100" type="index">
        </el-table-column>
        <el-table-column label="分类名称" prop="cate_name"></el-table-column>
        <el-table-column label="分类别名" prop="cate_alias"></el-table-column>
        <el-table-column label="操作" width="150">
          <template #default="{ row, $index }">
            <el-button
              size="large"
              :icon="Edit"
              circle
              type="primary"
              plain
              @click="onEditChannel(row)"
            >
            </el-button>
            <el-button
              size="large"
              :icon="Delete"
              circle
              plain
              type="danger"
              @click="onDeleteChannel(row, $index)"
            >
            </el-button>
          </template>
        </el-table-column>
        <template #empty>
          <el-empty description="没有数据" />
        </template>
      </el-table>
    </template>
  </PageContainer>
</template>

<style lang="scss" scoped></style>
